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Abstract 

Determining the maximal separation between sensitivity and block sensitivity 
of Boolean functions is of interest for computational complexity theory. We 
construct a sequence of Boolean functions with bs(f) — \s{f) 2 + |s(/). The 
best known separation previously was bs(f) — \s(f) 2 due to Rubinstein. We 
also report results of computer search for functions with at most 12 variables. 
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1. Introduction 

In his 1989 paper [lj Noam Nisan gives tight bounds for computing the value 
of a Boolean function in CREW-PRAM model. These bounds are expressed in 
terms of two complexity measures, namely the sensitivity and block sensitivity. 

Let w be a Boolean string of length n and let S be any subset of indices. 
Following definitions in [ljj, by w s we will mean w with all bits in S flipped. If 
f(w) 7^ f(w s ), we will say that / is sensitive to S on w. 

Definition 1. The sensitivity s(f,w) of f on the input w is defined as number 
of indices i such that f[w) ^ /(iu {i >), s(f,w) = \{i : f(w) £ The 
sensitivity s(f) of f is maxs(/, w). 

w 

Definition 2. The block sensitivity bs(f, w) of f on n inputs w\, . . . , w n (w = 
w\...w n ) is defined as maximum number of disjoint subsets B\,...,Bk of 
{1, 2, . . . , n} such that for each Bi, f(w) ^ f(w Bi ). The block sensitivity bs(f) 
of f is max bs(f, w) . 

w 

Block sensitivity is polynomially related to many other complexity measures 
such as decision tree complexity, certificate complexity, and quantum query 
complexity, among others [2[. The prime open problem associated with block 
sensitivity is whether sensitivity and block sensitivity are polynomially related. 

In 1992 Rubinstein proposed Q a Boolean function / for which bs(f) = 
\s{f) 2 , demonstrating a quadratic separation between these two complexity 
measures, which we quote in verbatim: 
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Theorem 1 (Rubinstein). For every n that is an even perfect square, we can 
construct a Boolean f on n variables with 2bs(f) = s(f) = n. 

Let Aj denote the interval Aj = {[i — l)-\/n + 1, . . . , i\/n} (i = 1, . . . , \fn). 

Let gi denote the Boolean function defined as follows: gi{H) = 1 exactly if 
H n A, = {2j — 1, 2j} for some j such that 2j € Aj. 

We define f to be join of all such gi: f(H) = gi(H) A ... A g^{H). 

It is believed that this separation is not far from optimal. However, the best 
known upper bound of block sensitivity in terms of sensitivity is exponential [3| • 

2. Our result 

In this paper we give an improvement on Rubinstein's example, in the case 
where the input length n is an odd square. Our function family is a modification 
of Rubinstein's, and our analysis is modelled on his. 

Theorem 2. For every non-negative integer k there exists a Boolean function 
f ofn = {2k + lf variables, for which s(f) = 2k + l and bs(f) = (2fc + l)(fc + l). 

Proof. We will divide variables into 2fc + 1 disjoint sections with 2fc + 1 variables 
in each section. We define / to be 1 iff there is a section x\,X2, ■ ■ ■ , X2k+i such 
that either: 

(i) X2i-i = x 2 i = 1 for some 1 < i < k and all other Xj's are 0, or 

(ii) X2k+i — 1 and all other Xj's are 0. 

We will call such section a "good" section. For any i, we will call X2i-i and 
X2i a "pair" . 

We observe that for input w = ... we have s(f, w) = 2fc+l and bs(f, w) = 
(2k + l)(fe + 1). We will now prove that these are extremal values for sensitivity 
and block sensitivity, respectively. 

Suppose we have an arbitrary input w. We will consider two cases: 

1. f(w) — 0. Then we claim that for each of 2k + 1 sections there is at most 
one bit whose change could flip the value of /. 

We will call a pair "incomplete" , if exactly one of its bits is set to 1 . We 
consider three cases based on the number of incomplete pairs in a section: 

(a) there are at least two "incomplete" pairs. Then we can't change the 
value of / by flipping just one bit, because doing so will leave at least 
one "incomplete" pair. 

(b) there is exactly one "incomplete" pair P. We first note that we can't 
make the section "good" without flipping a bit in P. If unsctting the 
1-bit in P makes the section "good" , then x 2 k+i = 1 or x 2 i-\ = x 2 i — 
1 for some 1 < i < k and setting the 0-bit in P will not make the 
section "good" . If setting the 0-bit in P makes the section "good" , 
then the only 1-bit in x is also in P and unsetting it will not make 
the section "good" . In cither case there is at most one choice for the 
bit to alter. 
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(c) there are no "incomplete" pairs. Then flipping any of Xi for 1 < 
i < 2k will introduce an "incomplete" pair and the section will not 
become "good". Therefore there is at most one bit whose change 
could flip the value of /, namely, X2k+i- 
2. f(w) = 1. If there are two "good" sections, we can't change the value of 
/ by flipping just one input bit. If there is only one "good" section, we 
have at most 2k + 1 choices for the bit to alter. 

This proves that s(f) < 2k + 1 and we indeed have s(f) = 2k + 1. 

We will now prove that bs(f) < (2k + l)(k + 1). Assume that the maximal 
block sensitivity is achieved using u blocks of size 1 and v blocks of size at 
least 2. Number of blocks of size 1 can't exceed the sensitivity of the function, 
therefore u < 2k + 1. The total size of all blocks is at most u + 2v, furthermore, 
the total size of all blocks can't exceed the total number of variables, therefore 
u + 2v < (2k + l) 2 . Taking these two inequalities together we obtain bs(f) — 
u + v = \(u+(u + 2v)) < \((2k + 1) + (2k + l) 2 ) = (2k + 1)0 + 1). □ 

This implies that for our function we have bs(f) = \s(j) 2 + ^s(f). Our 
function improves an inequality from an open problem in 

3. Maximal separation for functions of few variables 

We discovered our function by performing exhaustive computer search of all 
Boolean functions with at most 12 variables. 

The number of 12-variable Boolean functions is 2 and a brute-force ap- 
proach is clearly not feasible. In our experiments we reduced the block sen- 
sitivity problem to the SAT problem and used a SAT solver on the resulting 
problem instances. We built our SAT instances by considering 2 12 variables 
corresponding to the values of f(xi, X2, ■ • • X12) and additional variables and 
clauses to describe constraints s(f) < s and bs(f) > bs, for arbitrary constants 
s, bs. The SAT solver we used was cryptominisat [j| and it took us about a 
week of computing time. 

3.1. The constraint bs(f) > bs 

In order to describe bs(f) > bs we constructed one SAT instance for each 
partition of n into bs parts p\ , . . . , pb s ■ The semantic meaning for the constraint 
we will describe is "there is a function which is sensitive on blocks of sizes 
Pi, . . . ,Pbs" ■ The constraint bs(f) > 6s is feasible if and only if there exists a 
partition for which the constraint described below is satisfiable. 

We note that for any T C {1, . . . , n} and g(x) = f(x T ) we have s(f) = s(g) 
and bs(f) — bs(g). This permits us to assume, without loss of generality, that 
/ attains the maximal block sensitivity on input ... 0, furthermore we can 
assume that /(0 ... 0) = 0. If bs(f) > bs then by reordering variables we can 

i—l i—1 i 

enforce . . . 0) A A, /(0 . . . P < ) where P« = + $>;+2, . . . , 5>;}. 

This was our constraint. We used this constraint to enforce bs(f) > bs. 
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Table 1: All permissable (n, s, bs) triples for n < 12 



3.2. The constraint s(f) < s 

We constructed the constraint s(f) < s as a conjunction of constraints of 
the form s(f,w) < s, where w ranged over all 2™ inputs. 

We will now describe the setup for the constraint s(/, w) < s. Let bi be the 
variable denoting /(u>l l l). We used auxiliary variables and clauses to implement 
"counting" in unary. That is, we introduced new Boolean variables a±, . . . ,a n 
and defined a set of constraints that force ax + a>2 + ■ ■ ■ + o, n = bi + b% + . . . + b n 
and cii > ci2 > . . . > a n , essentially sorting the 6j's. 

If {cii} is a permutation of {bi} sorted in descending order, then the con- 
straint s(/, w) < s can be implemented as (^f(w) A^a s+ i)V (/(w) Aa„_ s ). The 
set of ai's was built incrementally using a dynamic programming table {cij} 
(0 < i,j < n), where cy = 1 iff at least j of bi, . . . , bi are 1. Following the 
semantic meaning of Ci_j we have the base conditions of c^.o = 1 and cy = 
(i < j). Furthermore, the following recurrence holds: cy = (cj_i i;; -_iA6i) VCj_ij 
(1 < j ' < i < n). This can be proved by considering two cases: if bi = 1 then 
Ci.j = Q-ij-i V c,:-ij = Ci_ij_i, because Ci-y — > Cj_ij-_i, if 6, = then 
Ci.j = Ci-i,fi both of these equalities agree with the definition of cy. The set 
of a^'s is exactly the last row of the matrix: = Ci^ n . 

3.3. Results 

We have summarized our results in Table [T] Our experiments show that for 
all functions with at most 12 variables bs(f) does not exceed \s{f) 2 + \s{j). 
This might suggest that our example is indeed optimal. Due to the results of 
Kenyon and Kutin, the best possible separation that can be achieved between 
the sensitivity and the block sensitivity for blocks of size at most 2 is quadratic, 
so the new result is not far from optimal in such sense. 
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